home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Aminet 2
/
Aminet AMIGA CDROM (1994)(Walnut Creek)[Feb 1994][W.O. 44790-1].iso
/
Aminet
/
text
/
dtp
/
t1utils.lha
/
t1utils
/
t1ascii.c
< prev
next >
Wrap
C/C++ Source or Header
|
1993-06-17
|
3KB
|
154 lines
/* t1ascii
**
** This program takes an Adobe Type-1 font program in binary (PFB) format and
** converts it to ASCII (PFA) format.
**
** Copyright (c) 1992 by I. Lee Hetherington, all rights reserved.
**
** Permission is hereby granted to use, modify, and distribute this program
** for any purpose provided this copyright notice and the one below remain
** intact.
**
** author: I. Lee Hetherington (ilh@lcs.mit.edu)
*/
#ifndef lint
static char sccsid[] =
"@(#) t1ascii.c 1.1 10:58:15 5/21/92";
static char copyright[] =
"@(#) Copyright (c) 1992 by I. Lee Hetherington, all rights reserved.";
#endif
/* Note: this is ANSI C. */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#ifdef MSDOS
#define RB "rb"
#else
#define RB "r"
#endif
#define BANNER "This is t1ascii 1.1.\n"
#define MARKER 128
#define ASCII 1
#define BINARY 2
#define DONE 3
static FILE *ifp = stdin;
static FILE *ofp = stdout;
/* This function reads a four-byte block length. */
static int read_length()
{
int length;
length = fgetc(ifp);
length |= fgetc(ifp) << 8;
length |= fgetc(ifp) << 16;
length |= fgetc(ifp) << 24;
return length;
}
/* This function outputs a single byte in hexadecimal. It limits hexadecimal
output to 64 columns. */
static void output_hex(int b)
{
static char *hexchar = "0123456789ABCDEF";
static int hexcol = 0;
/* trim hexadecimal lines to 64 columns */
if (hexcol >= 64) {
fputc('\n', ofp);
hexcol = 0;
}
fputc(hexchar[(b >> 4) & 0xf], ofp);
fputc(hexchar[b & 0xf], ofp);
hexcol += 2;
}
static void usage()
{
fprintf(stderr,
"usage: t1ascii [input [output]]\n");
exit(1);
}
int main(int argc, char **argv)
{
int c, block = 1, length, last_type = ASCII;
fprintf(stderr, "%s", BANNER);
if (argc > 3)
usage();
/* possibly open input & output files */
if (argc >= 2) {
ifp = fopen(argv[1], RB);
if (!ifp) {
fprintf(stderr, "error: cannot open %s for reading\n", argv[1]);
exit(1);
}
}
if (argc == 3) {
ofp = fopen(argv[2], "w");
if (!ofp) {
fprintf(stderr, "error: cannot open %s for writing\n", argv[2]);
exit(1);
}
}
/* main loop through blocks */
for (;;) {
c = fgetc(ifp);
if (c == EOF) {
break;
}
if (c != MARKER) {
fprintf(stderr,
"error: missing marker (128) at beginning of block %d",
block);
exit(1);
}
switch (c = fgetc(ifp)) {
case ASCII:
if (last_type != ASCII)
fputc('\n', ofp);
last_type = ASCII;
for (length = read_length(); length > 0; length--)
if ((c = fgetc(ifp)) == '\r')
fputc('\n', ofp);
else
fputc(c, ofp);
break;
case BINARY:
last_type = BINARY;
for (length = read_length(); length > 0; length--)
output_hex(fgetc(ifp));
break;
case DONE:
/* nothing to be done --- will exit at top of loop with EOF */
break;
default:
fprintf(stderr, "error: bad block type %d in block %d\n",
c, block);
break;
}
block++;
}
fclose(ifp);
fclose(ofp);
return 0;
}